## Claims

| ì  | 1. A processor operable to function in a multiprocessor computer system, the          |
|----|---------------------------------------------------------------------------------------|
| 2  | processor comprising:                                                                 |
| 3  | a bus interface to provide communication with other processors;                       |
| 4  | a local cache;                                                                        |
| 5  | a cache invalidation history table associated with the local cache; and               |
| 6  | a cache controller associated with the local cache, the cache controller              |
| 7  | operable to track invalidated cache lines by recording the line addresses of          |
| 8  | invalidated cache lines and an indicator indicating whether each of the               |
| 9  | invalidated cache lines recorded was invalidated via a clean-invalidate or a dirty-   |
| 10 | invalidate in the invalidation history table, and further operable to revalidate only |
| 11 | those invalidated cache lines recorded in the invalidation history table as having    |
| 12 | been clean-invalidate invalidated by monitoring the bus for cache line addresses      |
| 13 | of clean-invalidate invalidated cache lines recorded in the invalidation history      |
| 14 | table and for associated cache line data and by updating the invalidated cache        |
| 15 | line data with the cache line data associated with the recorded cache line            |
| 16 | addresses.                                                                            |

- 1 2. The processor of claim 1, further comprising a plurality of local caches
- 2 local to the processor.
- 1 3. The processor of claim 1, wherein the processor is a part of a node, and
- 2 further comprising at least one additional local cache local to the node.
- 1 4. The processor of claim 1, wherein the local cache is an L2 cache.
- 1 5. The processor of claim 1, wherein the local cache is a write-back cache.
- 1 6. The processor of claim 1, wherein the valid cache line data is present on Attorney Docket No. 884.220US2 11 Client Ref. No. P7902C

- 2 the bus due to a modified write-back.
- 1 7. The processor of claim 1, wherein the cache controller further comprises
- 2 a write-back bit associated with entries in the local cache that is set when either a
- 3 hit to the same line in another processor is detected or when the same line is
- 4 invalidated in another processor's cache, and wherein the system broadcasts
- 5 write-backs from a selected local cache only when the line being written back has
- 6 an associated write-back bit set.
- 1 8. The processor of claim 7, wherein the selected local cache is an L1
- 2 cache.
- 1 9. The processor of claim 7, wherein the write-back bit is set only when the
- 2 processor local to the local cache has write or exclusive write access to the line.
- 1 10. A cache control module associated with a local cache, the cache control
- 2 module operable to track invalidated cache lines by recording the line addresses
- 3 of invalidated cache lines and an indicator indicating whether each of the
- 4 invalidated cache lines recorded was invalidated via a clean-invalidate or a dirty-
- 5 invalidate in an invalidation history table, and further operable to revalidate only
- 6 those invalidated cache lines recorded in the invalidation history table as having
- 7 been clean-invalidate invalidated by monitoring the bus for cache line addresses
- 8 of clean-invalidate invalidated cache lines recorded in the invalidation history
- 9 table and for associated cache line data and by updating the invalidated cache
- line data with the cache line data associated with the recorded cache line
- 11 addresses.
- 1 11. The cache control module of claim 10, wherein the cache control
- 2 module comprises a part of an integrated circuit.
- 1 12. The cache control module of claim 11, wherein the integrated circuit Attorney Docket No. 884.220US2 12 Client Ref. No. P7902C

- 2 comprises part of a motherboard chipset.
- 1 13. The cache control module of claim 10, wherein the cache control module
- 2 is embodied at least partially as software executable on a processor.
- 1 14. The cache control module of claim 10, wherein the valid cache line data
- 2 is present on the bus due to a modified write-back.
- 1 15. The cache control module of claim 10, further comprising a write-back
- 2 bit associated with entries in the local cache that is set when either a hit to the
- 3 same line in another processor is detected or when the same line is invalidated in
- 4 another processor's cache, and wherein the system broadcasts write-backs from a
- 5 selected local cache only when the line being written back has an associated
- 6 write-back bit set.
- 1 16. The cache control module of claim 15, wherein the selected local cache
- 2 is an L1 cache.
- 1 17. The cache control module of claim 15, wherein the write-back bit is set
- 2 only when the processor local to the local cache has write or exclusive write
- 3 access to the line.